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(54) Microprocessor with hardware controlled power management and selectable input/output 
control pins 



(57) A data processing device includes a plurality of 
subcircuits and circuitry for generating clock signals 
thereto. Detection circuitry detects the assertion of a 
control signal and disabling circuitry is operable to dis- 
able the clock signals to one or more of the subcircuits 



responsive to the control signal. In addition, circuitry is 
provided for selectively decoupling one or more subcir- 
cuits with associated input/output pins such that pins as- 
sociated with enhanced features may be decoupled to 
provide compatibility with a desired microprocessor ar- 
chitecture. 
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Description 

TECHNICAL FIELD OF THE INVENTION 

This invention relates in general to integrated cir- 
cuits, and more particularly to a microprocessor having 
hardware controlled power management, and having 
selectable input/output pins. 

BACKGROUND OF THE INVENTION 

increasingly, electronit circuit manufacturers need 
to reduce the power consumption of their circuit boards. 
The conservation of power is particularly important in 
portable electronic devices, such as laptop or notebook 
computers, where the product is specifically designed 
for use in situations where power outlets are not avail- 
able. Since laptop and notebook computers must oper- 
ate using internal batteries or rechargeable battery 
packs for extended periods of time, the conservation of 
battery power becomes a primary concern. 

In a laptop or notebook computer, the largest con- 
sumer of power is the display. The proportion of power 
consumed by the display will vary depending on the 
technology used. Thus, laptop and notebook computer 
manufacturers have disabled the power to the display 
during periods of inartK/ity. Decoupling the display hum 
the power supply can be accomplished with fairly simple 
circuitry. 

The next largest consumer of power on a laptop or 
notebook computer is the CPU motherboard microproc- 
essor. Heretofore, computer manufacturers have used 
one or two techniques for reducing power consumption 
of the microprocessor during periods of inactivity. One 
technique reduces the speed of the system clock to a 
fraction of the normal operating frequency during peri- 
ods of inactivity. Since the power consumption of the mi- 
croprocessor is proportional to the frequency, reducing 
the frequency of the system clock also reduces the pow- 
er consumption of the microprocessor In an Intel 
80386DX microprocessor (manufactured by Intel Cor- 
poration of Santa Clara, California), reducing the oper- 
ating frequency from 33 MHz to 4 MHz reduces the typ- 
ical operating current of the microprocessor from 400 to 
approximately 100 milliamps. Nevertheless, an operat- 
ing current of 100 milliamps still poses a large power 
drain on the battery. 

A second technique for reducing power turns off the 
system clock during periods of inactivity. Turning off the 
system clock affects all circuitry on the motherboard. 
Consequently, the circuitry which disables the system 
clock must also save ail pertinent information in the mi- 
croprocessor and associated board logic and restore 
the data upon resumption of activity such that the state 
of the computer after resumption of the system clock will 
be identical to the state of the computer prior to disabling 
the system clock. As a result, this technique for consum- 
ing power is both costly because of the complicated cir- 



cuitry and slow because of the need to store and restore 
the state of the computer. 

Therefore, a need has arisen in the industry to pro- 
vide a method and apparatus for conserving power in 
5 an electronic device which significantly reduces the 
power drain of the microprocessor without the need for 
complicated external circuitry. 

SUMMARY OF THE INVENTION 

In accordance with the present invention, a method 
and apparatus is provided which provides significant ad- 
vantages in reducing the power consumption of, and 
providing enhanced features for, a microprocessor. 

'5 in one aspect of the present invention, a processing 
unit includes a plurality of subcircuits and circuitry for 
generating a clock signal thereto. Circuitry is provided 
for detecting the assertion of a control signal; responsive 
to the control signal, disabling circuitry disables the 

20 clock signal to one or more of the subcircuits. 

This aspect of the present invention provides signif- 
icant advantages over the prior art. A significant reduc- 
tion in the power consumed by a computer may be ef- 
fected by disabling the clock to the microprocessor cir- 

25 cuitry. The present invention allows the disabling and 
enabling of the microprocessor clock signals tn ha con- 
trolled by a single control signal. Further, an acknowl- 
edge signal may be provided to notify external circuitry 
of the suspended state of the microprocessor 

30 Another aspect of the present invention comprises 
a microprocessor having a plurality of input/output pins 
and processing circuitry coupled to the input/output 
pins. Circuitry is provided for selectively decoupling the 
processing circuitry from the input/output pins. 

35 in the preferred embodiment, tri-state buffers are 
coupled between the processing circuitry and the input/ 
output pins. The tri-state buffers are controlled by the 
output of a register The register may be part of a register 
file which is addressable via the input/output ports ac- 

40 cesses. Initially, the register is set to a predetermined 
value; in the preferred embodiment, the register is set 
such that the tri-state buffers are in a high impedance 
mode. 

This aspect of the present invention provides signif- 
4 5 icant advantages. Enhanced features may be provided 
in the microprocessor which require pins not found on 
other x86 compatible microprocessors. The enhanced 
feature pins may be selectively disabled by the tri-state 
devices to ensure compatibility with x86 microprocessor 
50 architecture. In situations where the enhanced features 
are supported, the pins may be selectively enabled 
through software. 

BRIEF DESCRIPTION OF THE DRAWINGS 

55 

For a more complete understanding of the present 
invention, and the advantages thereof, reference is now 
made to the following descriptions taken in conjunction 
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with the accompanying drawings, mi which: 

FIGURE 1 illustrates a block diagram of a computer 
system; 

FIGURE 2 illustrates a block diagram of the pre- 
ferred embodiment of a microprocessor used in the 
computer system of FIGURE 1 ; 
FIGURE 3 illustrates a detailed block diagram of 
portions of the microprocessor of FIGURE 2 related 
to the power management circuitry; 
FIGURE 4 illustrates a flow chart describing a pre- 
ferred embodiment of operation for reducing micro- 
processor power consumption; 
FIGURES 5a-b illustrate circuitry for enabling and 
disabling pins providing power management control 
signals; and 

FIGURE 6 illustrates a flow chart of the operation 
of software controlled embodiment for conserving 
microprocessor power consumption. 

DETAILED DESCRIPTION OF THE INVENTION 

The preferred embodiment of the present invention 
and its advantages are best understood by referring to 
FIGURES 1 -6 of the drawings, like numerals being used 
for like and corresponding parts of the various drawings. 

FIGURE 1 illustrates a block diagram of a computer 
system. The computer system 10 comprises a micro- 
processor CPU chip 1 2 CGupleci Lu a memory subsystem 
14, BIOS ROM 16 and logic circuit chips 18 (commonly 
referred to as the "chipset"). Microprocessor 12 is cou- 
pled to bus 20. Bus 20 is used to communicate with a 
number of peripheral devices, shown in FIGURE 1 as 
keyboard controller 22, video controller 24, I/O circuitry 
26 and disk controller 28. Keyboard controller 22 is cou- 
pled to keyboard 29. Disk controller 28 is coupled to hard 
disk 30 and floppy disk 32. Video controller 24 is coupled 
to display 34. An optional coprocessor 35 is coupled to 
microprocessor 12 and BIOS ROM 16. 

The computer system 10 shown in FIGURE 1 is a 
general-purpose architecture common to personal com- 
puters such as the IBM Personal Computer and com- 
patibles. The BIOS 16 (basic input/output system) is typ- 
ically a read-only memory which contains a set of pro- 
grams for performing the basic control and supervision 
operations for the computer system 10. The BIOS 16 
acts as an interface between the computer circuitry and 
the application software being executed by the CPU 12. 
Importantly, for power consumption purposes, the BIOS 
16 and logic 18 monitor selected circuitry to determine 
whether power consumption reduction procedures may 
be invoked. For example, the BIOS 16 and/or logic 18 
may monitor the display 34 to determine whether its out- 
put has changed over a predetermined time period. If 
not, the BIOS 16 may invoke procedures to disable pow- 
er to the display 34 (assuming computer system 10 is a 
portable computer) to conserve energy. Further, BIOS 
16 monitors microprocessor 12 to determine whether 



the microprocessor u... be idled without affecting oper- 
ation of the computer system 10. For example, the mi- 
croprocessor 12 may be executing a routine to wait for 
a character from the keyboard. In this case, the opera- 
s tion of the microprocessor can be suspended until a key 
is pressed. 

FIGURE 2 illustrates a detailed block diagram of the 
various subcircuits of a preferred embodiment of the mi- 
croprocessor 12. For purposes of illustration, the micro- 
w processor 12 will be described in connection with a mi- 
croprocessor which is pin-compatible and instruction- 
compatible with the 80x86 family of processors by Intel 
Corporation, specifically the 80386 microprocessor al- 
though the invention could be used in other processors 
as well. The microprocessor 12 comprises three main 
functional groups: the core circuitry 36, the memory cir- 
cuitry 38 and the bus controller 40. The core circuitry 36 
includes an instruction queue 42 coupled to an internal 
data bus 44. The output of the instruction queue 42 is 
coupled to a decoder 46 of the decode/sequence circuit- 
ry 47. The decode/sequence circuitry 47 also includes 
a sequencer 50 and an exception processor 86. The de- 
coder 46 is coupled to a microcode ROM 48, exception 
processor 86 and sequencer 50. The sequencer 50 is 
also coupled to the microcode ROM 48 and to an exe- 
cution unit 52. The execution unit includes a limit unit 
54, a multiplier unit 56, an adder unit 58, a shift unit 60, 
and a register fiip 62. The execution unii 52 is coupled 
to the microcode ROM 48 and to multiplexer and I/O reg- 
ister circuitry 64. The memory circuitry 38 comprises a 
memory management unit 66 coupled to a linear ad- 
dress bus 68 which is also connected to the execution 
unit 52 and an instruction/data cache memory 70. Mem- 
ory management unit 66 is further coupled to the internal 
data bus 44. A prefetch unit 72 is coupled between the 
memory management unit 66 and the cache 70. Bus 
controller 40 includes data buffers 74, address buffers 
76 and control circuitry 78. The data buffers 74 are cou- 
pled to the data I/O pins D31-D0, the address buffers 
76 are coupled to the address pins A31 -A2 and BE3#« 
BE0#. A data address bus 80 couples the memory man- 
agement unit 66, the cache 70 and the address buffer 
76. An instruction address bus 82 couples the prefetch 
unit 72, cache 70 and address buffer 76. The data buff- 
ers 74 are coupled to the internal data bus 44. 

Clock module 84 receives an external clock signal 
(CLK2) and generates CLKA (connected to the bus con- 
troller 40) and CLKB (coupled to the memory circuitry 
38 and the core circuitry 36). CLKA and CLKB are both 
clock signals of one-half the frequency of CLK2. Clock 
module 84 receives control signals from bus controller 
40. 

In operation, instructions are received by the micro- 
processor 1 2 from external memory under control of the 
memory management unit 66. For enhanced perform- 
ance, an instruction/data cache 70 caches instruction 
and data received through the bus controller 40. Instruc- 
tions are stored in the instruction queue 42 and are sub- 
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sequently translated by the decode circuitry 46 into mi- 
crocode. The sequencer points to the next address in 
the microcode ROM 48 under control of the decoder 46 
and the execution unit 52. The execution unit 52 proc- 
esses information under control of the microcode ROM 
48. 

In the preferred embodiment, the microprocessor 
1 2 has a static design, i.e., retention of data in the inter- 
nal memories and registers of the microprocessor 12 is 
not dependent upon the clock signal. As described in 
greater detail herein below, the clock module 84, under 
control of the bus controller 40, can disable clocks to the 
subcircuits of the core circuitry 36 and the memory cir- 
cuitry 38 while continuing to generate clock signals to 
the bus controller 40. Thus, during periods of inactivity, 
a large portion of the circuitry of the microprocessor may 
be suspended, thereby greatly reducing the power con- 
sumed by the microprocessor 12. 

FIGURES 3 and 4 describe the power reduction cir- 
cuitry in greater detail. FIGURE 3 is a block diagram 
showing control signals between various portions of the 
microprocessor. The bus controller 40 controls signals 
from external pins of the microprocessor 1 2. A suspend 
(SUSP) signal is input to the bus controller 40 and a sus- 
pend acknowledge (SUSPACK) is output from the bus 
controller 40. A busy (BUSY) is received by the bus con- 
troller 40 from the coprocessor 35 The buc controller 
40 also receives a maskable interrupt (INTR) and a non- 
maskable interrupt (NMI). The bus controller 40 outputs 
an interrupt (or 'exception') F_SUSP to the exception 
processor 86 and receives a control signal 
D_SUSPACK. The exception processor 86 also moni- 
tors the microcode ROM 48, bus controller 40 and exe- 
cution unit 52 to determine whether instructions are be- 
ing executed. The exception processor 86 outputs a sig- 
nal D_EXCEPTlON to the sequencer 50 and receives a 
control signal U_AHALT from the microcode ROM 48. 
The bus controller 40 outputs a control signal FJDLE 
to the clock module 84. 

In operation, an external circuit (typically the BIOS 
16 in conjunction with the logic 18) detects conditions 
where microprocessor operations could be suspended 
(for example, when the microprocessor is executing a 
routine to wait for a character from the keyboard). Upon 
detection of such a situation, the external circuit asserts 
the SUSP pin (for example, by driving the SUSP pin with 
a logical low voltage). In response to the assertion of the 
SUSP signal, the bus controller 40, in conjunction with 
the exception processor 86, asserts the FJDLE control 
signal to the clock module 84. In response to the asser- 
tion of the FJDLE signal, the clock module 84 disables 
the CLKB clock signals (by holding the disabled clock 
signal at a logical high or logical tow voltage), while con- 
tinuing to generating the CLKA clock signals. Since the 
design of the microprocessor is static, the memories do 
not require refreshing, and therefore suspending the 
clock will not result in a loss of data within the micro- 
processor 1 2. The SUSPACK signal is asserted to notify 



external circuitry that the microprocessor 12 is in the 
suspended state. To resume operation of the microproc- 
essor 12. the SUSP signal is de-asserted (i.e., by ap- 
plying a logical low voltage to the SUSP pin), for exam- 
5 pie, upon detection by BIOS 1 6 and logic 1 8 of a signal 
from the keyboard. 

By suspending the clocks to the core circuitry 36 
and memory circuitry 38. a significant reduction in the 
power consumed by the microprocessor 12 is realized. 

'0 The bus controller 40 remains active to observe and 
control I/O signals between the microprocessor 12 and 
the external circuitry. 

FIGURE 4 illustrates a flow chart showing a more 
detailed operation of the suspend mode. In decision 

'5 block 88, a loop is formed waiting for the SUSP signal 
to be asserted. In block 90, after the SUSP signal is as- 
serted, the bus controller 40 asserts the F_SUSP signal, 
which is coupled to the exception processor 86. In block 
92. in response to the assertion of the F_SUSP signal, 

20 the instruction queue 42 is prevented from advancing 
new instructions. In block 94, the decoder 46 ceases to 
advance new instructions to the microcode ROM 48 and 
any instructions currently being processed by the mi- 
crocode ROM 48 or execution unit 52 (collectively, the 

25 'pipeline") are completed, including any activity by the 
bus controller 40 related to the instructions in tho pip e - 
iine. Alter all instructions in the pipeline have been ex- 
ecuted, the control signal D_EXCEPTION is asserted 
by the exception processor 86 in block P. 

30 D_EXCEPTION is received by the sequencer 50 wtu 
initiates a power-down microcode routine (block 98) re- 
sponsive to D_EXCEPTION. The power-down microc- 
ode routine prepares the microprocessor for suspend 
mode. In block 100, the microcode ROM 48 asserts the 

35 control signal U_AHALT to the exception processor 86. 
In response to receiving U_AHALT the exception proc- 
essor 86 asserts D_SUSPACK to the bus controller 40 
in block 102. In decision 104, the bus controller 40, after 
receiving D_SUSPACK from the exception processor, 

40 checks the busy signal received from the coprocessor. 
So long as the busy signal from the coprocessor is as- 
serted, the SUSPACK signal to the external circuitry will 
not be asserted and CLKB will not be disabled. Once, 
the busy signal is de-asserted by the coprocessor, the 

45 SUSPACK signal is asserted by the bus controller 40 to 
alert the external circuitry that the microprocessor 12 is 
in a suspended state and that the coprocessor is not 
currently performing any calculations, and may also be 
suspended. In block 108, FJDLE is asserted by the bus 

50 controller 40 to the clock module 84. In response to the 
assertion of the FJDLE signal, the clock module 84 dis- 
ables the CLKB in block 109, thereby suspending oper- 
ation of the core circuitry 36 and memory circuitry 38. 
The bus controller 40 then waits until the SUSP signal 

55 is de-asserted in decision block 1 1 0. Upon de-assertion 
of the SUSP signal, CLKB is resumed. 

Most microprocessors, including the 80386, do not 
use all available pins on the chip package. Thus, the 
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SUSP and SUSPACK signals may ue communicated to 
and from the microprocessor 12 using unused pins, 
thereby maintaining compatibility with a pre-existing 
technology. Nonetheless, in the preferred embodiment, 
the pins tor the SUSP and SUSPACK signals may be s 
selectively enabled or disabled. In the preferred embod- 
iment, the SUSP and SUSPACK pins are initially disa- 
bled, and the BIOS 16 must be configured to enable the 
pins in its start-up routine. To effect enabling or disabling 
of the SUSP and SUSPACK pins, a control bit is provid- io 
ed which may be written to or read from via preselected 
I/O ports. The preferred embodiment of this aspect is 
shown in greater detail in connection with FIGURES 5a- 
b. 

In FIGURE 5a, a plurality of control registers in the '5 
microprocessor 12 (FIGURE 1 ) are accessible using IN- 
DEX and DATA signals input to the control registers 1 20. 
The majority of the registers (and bits thereof) are used 
for configuring the cache memory subsystem. For ex- 
ample, the control registers may be used to define non- 20 
cacheable regions of the main memory 14, to select the 
cache method (direct-mapped or set associative), and 
to enable flushing of the cache memory 70 via an exter- 
nal pin. Each control register is accessible by writing the 
address (referred to herein as the INDEX) of the register 25 
to an I/O port, shown in FIGURE 5a as I/O port 22h. 
Another I/O port, shown herein as I/O port 23h, is used 
to read or write data from the specified control register. 
!r. the pr^iarra^ enibuuimeni, eacn I/O port 23h opera- 
tion is preceded by an I/O port 22h operation, otherwise 30 
the second and later I/O port 23h operation would be 
directed off-chip. In the illustrated embodiment of FIG- 
URE 5a, the control registers each have an index be- 
tween COh and CFh. 

In FIGURE 5b, the register 122 having an index of 3S 
COh uses its least significant bit to control tri-state de- 
vices 124 and 126 (each of which includes, in addition 
to HI and LO states, a high impedance third state). A bit 
equal to a logical high (i.e., a logical °1°) enables both 
tri-state devices 1 24 and 1 26 to provide transmission of <o 
the SUSP and SUSPACK signals. A logical B 0* disables 
the tristate devices 124 and 126 and thereby isolates 
the SUSP and SUSPACK pins from the circuitry of the 
microprocessor 12. 

This aspect of the preferred embodiment ensures *s 
pin-compatibility with an existing microprocessor pin 
structures. 

FIGURE 6 illustrates another aspect of the present 
invention wherein the operation of the microprocessor 
12 may be suspended responsive to a software com- so 
mand. 

60x86 devices support a "HALT" operation (Opcode F4) 
which stops execution of all instructions and places the 
80x86 in a HALT state. Execution is resumed respon- 
sive to a non-maskable interrupt (on the NMI pin) cou- 55 
pled to the bus controller 40, an unmasked interrupt (on 
the INTR pin coupled to the bus controller 40) or a RE- 
SET. Normally, this instruction is used as the last instruc- 



tion in sequence whi^n shuts down the system. 

In the present invention, however, the HALT instruc- 
tion has essentially the same consequence as asserting 
the SUSP pin. Thus, the BIOS 16 can issue a HALT in- 
struction to the microprocessor 12, thereby disabling 
CLKB. Again, disabling CLKB will result in a significant 
reduction of power consumed by the microprocessor 1 2. 

FIGURE 6 illustrates a flow chart showing the op- 
eration of the HALT instruction in the preferred embod- 
iment. Once a HALT instruction to the microprocessor 
12 is received in decision block 130, U_AHALT is as- 
serted by the microcode ROM 46 in block 132. In re- 
sponse to the U_AHALT signal from the microcode 
ROM, the exception processor 86 asserts 
D_SUSPACK. After checking the busy signal from the 
coprocessor in decision block 1 36, the SUSPACK signal 
is asserted in block 1 40 by the bus controller 40 and the 
internal CLKB dock is disabled in block 142. In decision 
block 144, the microprocessor 12 remains in the sus- 
pended state until an interrupt is asserted in decision 
block 144. Once the interrupt is asserted, the CLKB 
clock is enabled and processing continues. 

The HALT instruction allows the BIOS 16 to place 
the microprocessor 12 in a suspended state without any 
additional hardware connections to the microprocessor. 

The present invention provides significant advan- 
tages over the prior art. By suspending the clocks to the 
core circuitry and memory circuitry, a cjrrenl ^uusump- 
tion of less than 10 milliamps has been demonstrated. 
Since most BIOS programs support power conservation 
measures, the additional coding for supporting the 
SUSP and SUSPACK signals is relatively simple. Alter- 
natively, the chipset logic 18 can be modified to support 
generation of the SUSP and SUSPACK signals. Further, 
since the SUSPACK, in the preferred embodiment, is 
not asserted until after coprocessor operations are com- 
pleted, the BIOS does not have to provide additional cir- 
cuitry or codes for monitoring the coprocessor. Further, 
the power saving circuitry may be provided on the mi- 
croprocessor chip without sacrificing pin-compatibility. 
Additionally, by using the enhanced HALT command, 
the microprocessor may be operated in a suspended 
state without any hardware interaction, other than as- 
serting an interrupt to bring the microprocessor 12 out 
of a suspended state. 

Although the present invention 'and its advantages 
have been described in detail, it should be understood 
that various changes, substitutions and alterations can 
be made herein without departing from the spirit and 
scope of the invention as defined by the appended 
claims. 



Claims 

1. A data processing device, comprising: 

a plurality of subcircuits (36, 3B. 40); 
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circuitry (84) for generating a clock signal to 
said plurality of subcircuits; and 
circuitry (40) coupled to detect the assertion of 
a control signal; and 

characterised by circuitry (84) coupled to re- 
spond to said detection to disable the clock signal 
to at least one of said subcircuits. 

2. The device of claim 1 further characterised by cir- 
cuitry (40) for generating an acknowledge signal in- 
dicating that the clock signal to said at least one of 
said subcircuits has been disabled. 

3. The device of claim 1 or 2 characterised in that said 
disabling circuitry comprises circuitry (86) for exe- 
cuting instructions currently in one or more of said 
subcircuits prior to disabling said at least one of said 
subcircuits. 

4. The device of claim 1 , 2 or 3 further characterised 
by circuitry (84) for resuming the clock signal to said 
at least one of said subcircuits responsive to de-as- 
sertion of said control signal. 

5. The device of claim 1 , 2, 3 or 4 further characterised 
by circuitrv for generating an jpterr'jp! rccpcr.cive to 
detecting assertion of said control signal. 

6. A computer comprising: 

a microprocessor (112) comprising: 

a plurality of subcircuits (36, 38, 40); 

circuitry (84) for generating a clock signal to 

said plurality of subcircuits; 

circuitry (40) for detecting the assertion of a 

control signal; and 

characterised by circuitry (84) coupled to said 
detecting circuitry for disabling the clock signal to 
ones of said subcircuits responsive to said control 
signal; 

circuitry (86) for detecting conditions for sus- 
pending operations of said processing unit and 
asserting said control signal responsive there- 
to; and 

circuitry (40) for detecting conditions for resum- 
ing operation of said processing unit and de- 
asserting said control signal responsive there- 
to. 

7. A method of conserving power consumed by a data 
processing device comprising the steps of: 

generating and applying a clock signal to a plu- 
rality of subcircuits; 

detecting the assertion of a control signal; and 



characterised by disabling the clock signal to 
ones of said subcircuits in response to said detect- 
ing. 

5 8. The method of claim 7 further characterised by the 
step of generating an acknowledge signal indicating 
that the clock signal to said ones of said subcircuits 
has been disabled. 

to 9. The method of claim 7 or 8 characterised in that said 
disabling step comprises delaying disabling the 
clock signal to said ones of said subcircuits until af- 
ter executing instructions currently in ones of said 
subcircuits. 

75 

10. The method of claim 7, 8 or 9 further characterised 
by the step of resuming the clock signal to said ones 
of said subcircuits responsive to de-assertion of 
said control signal. 

20 

11. A microprocessor comprising: 

a plurality of input/output pins (22. 23); 
data processing circuitry (120) coupled to said 
25 input/output pins for communicating therewith: 

and 

characterised by circuitry (122, 124, 126)op- 
erabie to selectively decouple said processing cir- 
30 cuitry from said one or more of input/output pins. 

12. The microprocessor of claim 11, characterised in 
that said circuitry for selectively decoupling com- 
prises: 

35 

a tristate buffer (124, 126); and 
control circuitry, preferably a register (122), op- 
erable to control said tristate buffer. 

to 13. A microprocessor comprising: 

a plurality of input/output pins; 
an internal bus (44); 

a bus controller (40) coupled to said input/out- 
45 put pins and said bus for controlling communi- 

cations between said input/output pins and said 
internal bus; and 

characterised by one or more switches, pref- 
50 erably tri-state buffers (124, 126), for selectively 
coupling respective input/output pins to the bus 
controller; and 

a register (122) for storing data to control said 
switches. 

55 

14. The microprocessor of claim 1 3 wherein said regis- 
ter is addressed via an input/output port access 
(22), and is preferably written to through a second 
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input/output port access (23). 

15. A method of providing communications in a micro- 
processor comprising the steps of: 

storing a control value in a register; and in re- 5 
sponse to the output of said register 

characterised by controlling one or more 
switches onboard said microprocessor coupled to 
respective input/output pins to selectively commu- 
nicate data with said input/output pins. 10 

16. The method of claim 15 wherein said control value 
is stored in one register of a register file by: 

addressing said one register via a first input/ *5 
output port access; and 
writing to said addressed register through a 
second input/output port access. 
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